import { Message } from 'element-ui'
import store from '@/store'
import router from '@/router'

// 封装axios用于发送请求
import axios from 'axios'
//  创建一个新的axios实例
const request = axios.create({
  baseURL: 'http://interview-api-t.itheima.net/',
  timeout: 10000
})

// 请求拦截器
request.interceptors.request.use((config) => {
  // 在发送请求之前做些什么
  const token = store.state.user.token
  if (token) {
    config.headers.Authorization = `Bearer ${token}`
  }
  return config
}, (error) => {
  return Promise.reject(error)
})

// 相应拦截器
request.interceptors.response.use((res) => {
  return res.data
}, (error) => {
  // 所有的响应错误信息，统一处理
  if (error.response) {
    if (error.response.status === 401) {
      // 提示用户
      Message.warning('尊敬的用户，当前登录状态已过期！')
      // 清除token
      store.commit('user/logout')
      // 跳转到登录页
      router.replace('/login')
    } else {
      Message.error(error.response.data.message)
    }
  }
  // 对响应错误做点什么
  return Promise.reject(error)
})

export default request
